package com.xb.cloud.product.service.business.model;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class ShopNavigationGroupExample {
    protected String orderByClause;

    protected boolean distinct;

    protected List<Criteria> oredCriteria;

    public ShopNavigationGroupExample() {
        oredCriteria = new ArrayList<Criteria>();
    }

    public void setOrderByClause(String orderByClause) {
        this.orderByClause = orderByClause;
    }

    public String getOrderByClause() {
        return orderByClause;
    }

    public void setDistinct(boolean distinct) {
        this.distinct = distinct;
    }

    public boolean isDistinct() {
        return distinct;
    }

    public List<Criteria> getOredCriteria() {
        return oredCriteria;
    }

    public void or(Criteria criteria) {
        oredCriteria.add(criteria);
    }

    public Criteria or() {
        Criteria criteria = createCriteriaInternal();
        oredCriteria.add(criteria);
        return criteria;
    }

    public Criteria createCriteria() {
        Criteria criteria = createCriteriaInternal();
        if (oredCriteria.size() == 0) {
            oredCriteria.add(criteria);
        }
        return criteria;
    }

    protected Criteria createCriteriaInternal() {
        Criteria criteria = new Criteria();
        return criteria;
    }

    public void clear() {
        oredCriteria.clear();
        orderByClause = null;
        distinct = false;
    }

    protected abstract static class GeneratedCriteria {
        protected List<Criterion> criteria;

        protected GeneratedCriteria() {
            super();
            criteria = new ArrayList<Criterion>();
        }

        public boolean isValid() {
            return criteria.size() > 0;
        }

        public List<Criterion> getAllCriteria() {
            return criteria;
        }

        public List<Criterion> getCriteria() {
            return criteria;
        }

        protected void addCriterion(String condition) {
            if (condition == null) {
                throw new RuntimeException("Value for condition cannot be null");
            }
            criteria.add(new Criterion(condition));
        }

        protected void addCriterion(String condition, Object value, String property) {
            if (value == null) {
                throw new RuntimeException("Value for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value));
        }

        protected void addCriterion(String condition, Object value1, Object value2, String property) {
            if (value1 == null || value2 == null) {
                throw new RuntimeException("Between values for " + property + " cannot be null");
            }
            criteria.add(new Criterion(condition, value1, value2));
        }

        public Criteria andIdIsNull() {
            addCriterion("id is null");
            return (Criteria) this;
        }

        public Criteria andIdIsNotNull() {
            addCriterion("id is not null");
            return (Criteria) this;
        }

        public Criteria andIdEqualTo(Long value) {
            addCriterion("id =", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotEqualTo(Long value) {
            addCriterion("id <>", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThan(Long value) {
            addCriterion("id >", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdGreaterThanOrEqualTo(Long value) {
            addCriterion("id >=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThan(Long value) {
            addCriterion("id <", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdLessThanOrEqualTo(Long value) {
            addCriterion("id <=", value, "id");
            return (Criteria) this;
        }

        public Criteria andIdIn(List<Long> values) {
            addCriterion("id in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotIn(List<Long> values) {
            addCriterion("id not in", values, "id");
            return (Criteria) this;
        }

        public Criteria andIdBetween(Long value1, Long value2) {
            addCriterion("id between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andIdNotBetween(Long value1, Long value2) {
            addCriterion("id not between", value1, value2, "id");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIsNull() {
            addCriterion("company_id is null");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIsNotNull() {
            addCriterion("company_id is not null");
            return (Criteria) this;
        }

        public Criteria andCompanyIdEqualTo(Long value) {
            addCriterion("company_id =", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotEqualTo(Long value) {
            addCriterion("company_id <>", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdGreaterThan(Long value) {
            addCriterion("company_id >", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdGreaterThanOrEqualTo(Long value) {
            addCriterion("company_id >=", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdLessThan(Long value) {
            addCriterion("company_id <", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdLessThanOrEqualTo(Long value) {
            addCriterion("company_id <=", value, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdIn(List<Long> values) {
            addCriterion("company_id in", values, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotIn(List<Long> values) {
            addCriterion("company_id not in", values, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdBetween(Long value1, Long value2) {
            addCriterion("company_id between", value1, value2, "companyId");
            return (Criteria) this;
        }

        public Criteria andCompanyIdNotBetween(Long value1, Long value2) {
            addCriterion("company_id not between", value1, value2, "companyId");
            return (Criteria) this;
        }

        public Criteria andShopIdIsNull() {
            addCriterion("shop_id is null");
            return (Criteria) this;
        }

        public Criteria andShopIdIsNotNull() {
            addCriterion("shop_id is not null");
            return (Criteria) this;
        }

        public Criteria andShopIdEqualTo(Long value) {
            addCriterion("shop_id =", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdNotEqualTo(Long value) {
            addCriterion("shop_id <>", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdGreaterThan(Long value) {
            addCriterion("shop_id >", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdGreaterThanOrEqualTo(Long value) {
            addCriterion("shop_id >=", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdLessThan(Long value) {
            addCriterion("shop_id <", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdLessThanOrEqualTo(Long value) {
            addCriterion("shop_id <=", value, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdIn(List<Long> values) {
            addCriterion("shop_id in", values, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdNotIn(List<Long> values) {
            addCriterion("shop_id not in", values, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdBetween(Long value1, Long value2) {
            addCriterion("shop_id between", value1, value2, "shopId");
            return (Criteria) this;
        }

        public Criteria andShopIdNotBetween(Long value1, Long value2) {
            addCriterion("shop_id not between", value1, value2, "shopId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdIsNull() {
            addCriterion("group_parent_id is null");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdIsNotNull() {
            addCriterion("group_parent_id is not null");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdEqualTo(Long value) {
            addCriterion("group_parent_id =", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdNotEqualTo(Long value) {
            addCriterion("group_parent_id <>", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdGreaterThan(Long value) {
            addCriterion("group_parent_id >", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdGreaterThanOrEqualTo(Long value) {
            addCriterion("group_parent_id >=", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdLessThan(Long value) {
            addCriterion("group_parent_id <", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdLessThanOrEqualTo(Long value) {
            addCriterion("group_parent_id <=", value, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdIn(List<Long> values) {
            addCriterion("group_parent_id in", values, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdNotIn(List<Long> values) {
            addCriterion("group_parent_id not in", values, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdBetween(Long value1, Long value2) {
            addCriterion("group_parent_id between", value1, value2, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupParentIdNotBetween(Long value1, Long value2) {
            addCriterion("group_parent_id not between", value1, value2, "groupParentId");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafIsNull() {
            addCriterion("group_is_leaf is null");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafIsNotNull() {
            addCriterion("group_is_leaf is not null");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafEqualTo(Byte value) {
            addCriterion("group_is_leaf =", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafNotEqualTo(Byte value) {
            addCriterion("group_is_leaf <>", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafGreaterThan(Byte value) {
            addCriterion("group_is_leaf >", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafGreaterThanOrEqualTo(Byte value) {
            addCriterion("group_is_leaf >=", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafLessThan(Byte value) {
            addCriterion("group_is_leaf <", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafLessThanOrEqualTo(Byte value) {
            addCriterion("group_is_leaf <=", value, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafIn(List<Byte> values) {
            addCriterion("group_is_leaf in", values, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafNotIn(List<Byte> values) {
            addCriterion("group_is_leaf not in", values, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafBetween(Byte value1, Byte value2) {
            addCriterion("group_is_leaf between", value1, value2, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupIsLeafNotBetween(Byte value1, Byte value2) {
            addCriterion("group_is_leaf not between", value1, value2, "groupIsLeaf");
            return (Criteria) this;
        }

        public Criteria andGroupNameIsNull() {
            addCriterion("group_name is null");
            return (Criteria) this;
        }

        public Criteria andGroupNameIsNotNull() {
            addCriterion("group_name is not null");
            return (Criteria) this;
        }

        public Criteria andGroupNameEqualTo(String value) {
            addCriterion("group_name =", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotEqualTo(String value) {
            addCriterion("group_name <>", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameGreaterThan(String value) {
            addCriterion("group_name >", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameGreaterThanOrEqualTo(String value) {
            addCriterion("group_name >=", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLessThan(String value) {
            addCriterion("group_name <", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLessThanOrEqualTo(String value) {
            addCriterion("group_name <=", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameLike(String value) {
            addCriterion("group_name like", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotLike(String value) {
            addCriterion("group_name not like", value, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameIn(List<String> values) {
            addCriterion("group_name in", values, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotIn(List<String> values) {
            addCriterion("group_name not in", values, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameBetween(String value1, String value2) {
            addCriterion("group_name between", value1, value2, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupNameNotBetween(String value1, String value2) {
            addCriterion("group_name not between", value1, value2, "groupName");
            return (Criteria) this;
        }

        public Criteria andGroupCodeIsNull() {
            addCriterion("group_code is null");
            return (Criteria) this;
        }

        public Criteria andGroupCodeIsNotNull() {
            addCriterion("group_code is not null");
            return (Criteria) this;
        }

        public Criteria andGroupCodeEqualTo(String value) {
            addCriterion("group_code =", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeNotEqualTo(String value) {
            addCriterion("group_code <>", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeGreaterThan(String value) {
            addCriterion("group_code >", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeGreaterThanOrEqualTo(String value) {
            addCriterion("group_code >=", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeLessThan(String value) {
            addCriterion("group_code <", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeLessThanOrEqualTo(String value) {
            addCriterion("group_code <=", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeLike(String value) {
            addCriterion("group_code like", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeNotLike(String value) {
            addCriterion("group_code not like", value, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeIn(List<String> values) {
            addCriterion("group_code in", values, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeNotIn(List<String> values) {
            addCriterion("group_code not in", values, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeBetween(String value1, String value2) {
            addCriterion("group_code between", value1, value2, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupCodeNotBetween(String value1, String value2) {
            addCriterion("group_code not between", value1, value2, "groupCode");
            return (Criteria) this;
        }

        public Criteria andGroupDescIsNull() {
            addCriterion("group_desc is null");
            return (Criteria) this;
        }

        public Criteria andGroupDescIsNotNull() {
            addCriterion("group_desc is not null");
            return (Criteria) this;
        }

        public Criteria andGroupDescEqualTo(String value) {
            addCriterion("group_desc =", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescNotEqualTo(String value) {
            addCriterion("group_desc <>", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescGreaterThan(String value) {
            addCriterion("group_desc >", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescGreaterThanOrEqualTo(String value) {
            addCriterion("group_desc >=", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescLessThan(String value) {
            addCriterion("group_desc <", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescLessThanOrEqualTo(String value) {
            addCriterion("group_desc <=", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescLike(String value) {
            addCriterion("group_desc like", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescNotLike(String value) {
            addCriterion("group_desc not like", value, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescIn(List<String> values) {
            addCriterion("group_desc in", values, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescNotIn(List<String> values) {
            addCriterion("group_desc not in", values, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescBetween(String value1, String value2) {
            addCriterion("group_desc between", value1, value2, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupDescNotBetween(String value1, String value2) {
            addCriterion("group_desc not between", value1, value2, "groupDesc");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordIsNull() {
            addCriterion("group_keyword is null");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordIsNotNull() {
            addCriterion("group_keyword is not null");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordEqualTo(String value) {
            addCriterion("group_keyword =", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordNotEqualTo(String value) {
            addCriterion("group_keyword <>", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordGreaterThan(String value) {
            addCriterion("group_keyword >", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordGreaterThanOrEqualTo(String value) {
            addCriterion("group_keyword >=", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordLessThan(String value) {
            addCriterion("group_keyword <", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordLessThanOrEqualTo(String value) {
            addCriterion("group_keyword <=", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordLike(String value) {
            addCriterion("group_keyword like", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordNotLike(String value) {
            addCriterion("group_keyword not like", value, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordIn(List<String> values) {
            addCriterion("group_keyword in", values, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordNotIn(List<String> values) {
            addCriterion("group_keyword not in", values, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordBetween(String value1, String value2) {
            addCriterion("group_keyword between", value1, value2, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupKeywordNotBetween(String value1, String value2) {
            addCriterion("group_keyword not between", value1, value2, "groupKeyword");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameIsNull() {
            addCriterion("group_search_name is null");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameIsNotNull() {
            addCriterion("group_search_name is not null");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameEqualTo(String value) {
            addCriterion("group_search_name =", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameNotEqualTo(String value) {
            addCriterion("group_search_name <>", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameGreaterThan(String value) {
            addCriterion("group_search_name >", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameGreaterThanOrEqualTo(String value) {
            addCriterion("group_search_name >=", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameLessThan(String value) {
            addCriterion("group_search_name <", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameLessThanOrEqualTo(String value) {
            addCriterion("group_search_name <=", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameLike(String value) {
            addCriterion("group_search_name like", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameNotLike(String value) {
            addCriterion("group_search_name not like", value, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameIn(List<String> values) {
            addCriterion("group_search_name in", values, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameNotIn(List<String> values) {
            addCriterion("group_search_name not in", values, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameBetween(String value1, String value2) {
            addCriterion("group_search_name between", value1, value2, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupSearchNameNotBetween(String value1, String value2) {
            addCriterion("group_search_name not between", value1, value2, "groupSearchName");
            return (Criteria) this;
        }

        public Criteria andGroupLevelIsNull() {
            addCriterion("group_level is null");
            return (Criteria) this;
        }

        public Criteria andGroupLevelIsNotNull() {
            addCriterion("group_level is not null");
            return (Criteria) this;
        }

        public Criteria andGroupLevelEqualTo(Byte value) {
            addCriterion("group_level =", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelNotEqualTo(Byte value) {
            addCriterion("group_level <>", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelGreaterThan(Byte value) {
            addCriterion("group_level >", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelGreaterThanOrEqualTo(Byte value) {
            addCriterion("group_level >=", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelLessThan(Byte value) {
            addCriterion("group_level <", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelLessThanOrEqualTo(Byte value) {
            addCriterion("group_level <=", value, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelIn(List<Byte> values) {
            addCriterion("group_level in", values, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelNotIn(List<Byte> values) {
            addCriterion("group_level not in", values, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelBetween(Byte value1, Byte value2) {
            addCriterion("group_level between", value1, value2, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupLevelNotBetween(Byte value1, Byte value2) {
            addCriterion("group_level not between", value1, value2, "groupLevel");
            return (Criteria) this;
        }

        public Criteria andGroupSortIsNull() {
            addCriterion("group_sort is null");
            return (Criteria) this;
        }

        public Criteria andGroupSortIsNotNull() {
            addCriterion("group_sort is not null");
            return (Criteria) this;
        }

        public Criteria andGroupSortEqualTo(Integer value) {
            addCriterion("group_sort =", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortNotEqualTo(Integer value) {
            addCriterion("group_sort <>", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortGreaterThan(Integer value) {
            addCriterion("group_sort >", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortGreaterThanOrEqualTo(Integer value) {
            addCriterion("group_sort >=", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortLessThan(Integer value) {
            addCriterion("group_sort <", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortLessThanOrEqualTo(Integer value) {
            addCriterion("group_sort <=", value, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortIn(List<Integer> values) {
            addCriterion("group_sort in", values, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortNotIn(List<Integer> values) {
            addCriterion("group_sort not in", values, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortBetween(Integer value1, Integer value2) {
            addCriterion("group_sort between", value1, value2, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupSortNotBetween(Integer value1, Integer value2) {
            addCriterion("group_sort not between", value1, value2, "groupSort");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlIsNull() {
            addCriterion("group_icon_url is null");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlIsNotNull() {
            addCriterion("group_icon_url is not null");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlEqualTo(String value) {
            addCriterion("group_icon_url =", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlNotEqualTo(String value) {
            addCriterion("group_icon_url <>", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlGreaterThan(String value) {
            addCriterion("group_icon_url >", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlGreaterThanOrEqualTo(String value) {
            addCriterion("group_icon_url >=", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlLessThan(String value) {
            addCriterion("group_icon_url <", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlLessThanOrEqualTo(String value) {
            addCriterion("group_icon_url <=", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlLike(String value) {
            addCriterion("group_icon_url like", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlNotLike(String value) {
            addCriterion("group_icon_url not like", value, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlIn(List<String> values) {
            addCriterion("group_icon_url in", values, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlNotIn(List<String> values) {
            addCriterion("group_icon_url not in", values, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlBetween(String value1, String value2) {
            addCriterion("group_icon_url between", value1, value2, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andGroupIconUrlNotBetween(String value1, String value2) {
            addCriterion("group_icon_url not between", value1, value2, "groupIconUrl");
            return (Criteria) this;
        }

        public Criteria andLayerNoIsNull() {
            addCriterion("layer_no is null");
            return (Criteria) this;
        }

        public Criteria andLayerNoIsNotNull() {
            addCriterion("layer_no is not null");
            return (Criteria) this;
        }

        public Criteria andLayerNoEqualTo(Integer value) {
            addCriterion("layer_no =", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoNotEqualTo(Integer value) {
            addCriterion("layer_no <>", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoGreaterThan(Integer value) {
            addCriterion("layer_no >", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoGreaterThanOrEqualTo(Integer value) {
            addCriterion("layer_no >=", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoLessThan(Integer value) {
            addCriterion("layer_no <", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoLessThanOrEqualTo(Integer value) {
            addCriterion("layer_no <=", value, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoIn(List<Integer> values) {
            addCriterion("layer_no in", values, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoNotIn(List<Integer> values) {
            addCriterion("layer_no not in", values, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoBetween(Integer value1, Integer value2) {
            addCriterion("layer_no between", value1, value2, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayerNoNotBetween(Integer value1, Integer value2) {
            addCriterion("layer_no not between", value1, value2, "layerNo");
            return (Criteria) this;
        }

        public Criteria andLayersIsNull() {
            addCriterion("layers is null");
            return (Criteria) this;
        }

        public Criteria andLayersIsNotNull() {
            addCriterion("layers is not null");
            return (Criteria) this;
        }

        public Criteria andLayersEqualTo(String value) {
            addCriterion("layers =", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersNotEqualTo(String value) {
            addCriterion("layers <>", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersGreaterThan(String value) {
            addCriterion("layers >", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersGreaterThanOrEqualTo(String value) {
            addCriterion("layers >=", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersLessThan(String value) {
            addCriterion("layers <", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersLessThanOrEqualTo(String value) {
            addCriterion("layers <=", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersLike(String value) {
            addCriterion("layers like", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersNotLike(String value) {
            addCriterion("layers not like", value, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersIn(List<String> values) {
            addCriterion("layers in", values, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersNotIn(List<String> values) {
            addCriterion("layers not in", values, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersBetween(String value1, String value2) {
            addCriterion("layers between", value1, value2, "layers");
            return (Criteria) this;
        }

        public Criteria andLayersNotBetween(String value1, String value2) {
            addCriterion("layers not between", value1, value2, "layers");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIsNull() {
            addCriterion("is_enabled is null");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIsNotNull() {
            addCriterion("is_enabled is not null");
            return (Criteria) this;
        }

        public Criteria andIsEnabledEqualTo(Byte value) {
            addCriterion("is_enabled =", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotEqualTo(Byte value) {
            addCriterion("is_enabled <>", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledGreaterThan(Byte value) {
            addCriterion("is_enabled >", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledGreaterThanOrEqualTo(Byte value) {
            addCriterion("is_enabled >=", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledLessThan(Byte value) {
            addCriterion("is_enabled <", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledLessThanOrEqualTo(Byte value) {
            addCriterion("is_enabled <=", value, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledIn(List<Byte> values) {
            addCriterion("is_enabled in", values, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotIn(List<Byte> values) {
            addCriterion("is_enabled not in", values, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledBetween(Byte value1, Byte value2) {
            addCriterion("is_enabled between", value1, value2, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsEnabledNotBetween(Byte value1, Byte value2) {
            addCriterion("is_enabled not between", value1, value2, "isEnabled");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIsNull() {
            addCriterion("is_deleted is null");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIsNotNull() {
            addCriterion("is_deleted is not null");
            return (Criteria) this;
        }

        public Criteria andIsDeletedEqualTo(Byte value) {
            addCriterion("is_deleted =", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotEqualTo(Byte value) {
            addCriterion("is_deleted <>", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedGreaterThan(Byte value) {
            addCriterion("is_deleted >", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedGreaterThanOrEqualTo(Byte value) {
            addCriterion("is_deleted >=", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedLessThan(Byte value) {
            addCriterion("is_deleted <", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedLessThanOrEqualTo(Byte value) {
            addCriterion("is_deleted <=", value, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedIn(List<Byte> values) {
            addCriterion("is_deleted in", values, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotIn(List<Byte> values) {
            addCriterion("is_deleted not in", values, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedBetween(Byte value1, Byte value2) {
            addCriterion("is_deleted between", value1, value2, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andIsDeletedNotBetween(Byte value1, Byte value2) {
            addCriterion("is_deleted not between", value1, value2, "isDeleted");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIsNull() {
            addCriterion("create_user_id is null");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIsNotNull() {
            addCriterion("create_user_id is not null");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdEqualTo(Long value) {
            addCriterion("create_user_id =", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotEqualTo(Long value) {
            addCriterion("create_user_id <>", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdGreaterThan(Long value) {
            addCriterion("create_user_id >", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdGreaterThanOrEqualTo(Long value) {
            addCriterion("create_user_id >=", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdLessThan(Long value) {
            addCriterion("create_user_id <", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdLessThanOrEqualTo(Long value) {
            addCriterion("create_user_id <=", value, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdIn(List<Long> values) {
            addCriterion("create_user_id in", values, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotIn(List<Long> values) {
            addCriterion("create_user_id not in", values, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdBetween(Long value1, Long value2) {
            addCriterion("create_user_id between", value1, value2, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserIdNotBetween(Long value1, Long value2) {
            addCriterion("create_user_id not between", value1, value2, "createUserId");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIsNull() {
            addCriterion("create_user_name is null");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIsNotNull() {
            addCriterion("create_user_name is not null");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameEqualTo(String value) {
            addCriterion("create_user_name =", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotEqualTo(String value) {
            addCriterion("create_user_name <>", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameGreaterThan(String value) {
            addCriterion("create_user_name >", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameGreaterThanOrEqualTo(String value) {
            addCriterion("create_user_name >=", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLessThan(String value) {
            addCriterion("create_user_name <", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLessThanOrEqualTo(String value) {
            addCriterion("create_user_name <=", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameLike(String value) {
            addCriterion("create_user_name like", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotLike(String value) {
            addCriterion("create_user_name not like", value, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameIn(List<String> values) {
            addCriterion("create_user_name in", values, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotIn(List<String> values) {
            addCriterion("create_user_name not in", values, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameBetween(String value1, String value2) {
            addCriterion("create_user_name between", value1, value2, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateUserNameNotBetween(String value1, String value2) {
            addCriterion("create_user_name not between", value1, value2, "createUserName");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNull() {
            addCriterion("create_time is null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIsNotNull() {
            addCriterion("create_time is not null");
            return (Criteria) this;
        }

        public Criteria andCreateTimeEqualTo(Date value) {
            addCriterion("create_time =", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotEqualTo(Date value) {
            addCriterion("create_time <>", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThan(Date value) {
            addCriterion("create_time >", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("create_time >=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThan(Date value) {
            addCriterion("create_time <", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeLessThanOrEqualTo(Date value) {
            addCriterion("create_time <=", value, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeIn(List<Date> values) {
            addCriterion("create_time in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotIn(List<Date> values) {
            addCriterion("create_time not in", values, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeBetween(Date value1, Date value2) {
            addCriterion("create_time between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andCreateTimeNotBetween(Date value1, Date value2) {
            addCriterion("create_time not between", value1, value2, "createTime");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIsNull() {
            addCriterion("update_user_id is null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIsNotNull() {
            addCriterion("update_user_id is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdEqualTo(Long value) {
            addCriterion("update_user_id =", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotEqualTo(Long value) {
            addCriterion("update_user_id <>", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdGreaterThan(Long value) {
            addCriterion("update_user_id >", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdGreaterThanOrEqualTo(Long value) {
            addCriterion("update_user_id >=", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdLessThan(Long value) {
            addCriterion("update_user_id <", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdLessThanOrEqualTo(Long value) {
            addCriterion("update_user_id <=", value, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdIn(List<Long> values) {
            addCriterion("update_user_id in", values, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotIn(List<Long> values) {
            addCriterion("update_user_id not in", values, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdBetween(Long value1, Long value2) {
            addCriterion("update_user_id between", value1, value2, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserIdNotBetween(Long value1, Long value2) {
            addCriterion("update_user_id not between", value1, value2, "updateUserId");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIsNull() {
            addCriterion("update_user_name is null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIsNotNull() {
            addCriterion("update_user_name is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameEqualTo(String value) {
            addCriterion("update_user_name =", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotEqualTo(String value) {
            addCriterion("update_user_name <>", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameGreaterThan(String value) {
            addCriterion("update_user_name >", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameGreaterThanOrEqualTo(String value) {
            addCriterion("update_user_name >=", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLessThan(String value) {
            addCriterion("update_user_name <", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLessThanOrEqualTo(String value) {
            addCriterion("update_user_name <=", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameLike(String value) {
            addCriterion("update_user_name like", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotLike(String value) {
            addCriterion("update_user_name not like", value, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameIn(List<String> values) {
            addCriterion("update_user_name in", values, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotIn(List<String> values) {
            addCriterion("update_user_name not in", values, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameBetween(String value1, String value2) {
            addCriterion("update_user_name between", value1, value2, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateUserNameNotBetween(String value1, String value2) {
            addCriterion("update_user_name not between", value1, value2, "updateUserName");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNull() {
            addCriterion("update_time is null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIsNotNull() {
            addCriterion("update_time is not null");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeEqualTo(Date value) {
            addCriterion("update_time =", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotEqualTo(Date value) {
            addCriterion("update_time <>", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThan(Date value) {
            addCriterion("update_time >", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeGreaterThanOrEqualTo(Date value) {
            addCriterion("update_time >=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThan(Date value) {
            addCriterion("update_time <", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeLessThanOrEqualTo(Date value) {
            addCriterion("update_time <=", value, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeIn(List<Date> values) {
            addCriterion("update_time in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotIn(List<Date> values) {
            addCriterion("update_time not in", values, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeBetween(Date value1, Date value2) {
            addCriterion("update_time between", value1, value2, "updateTime");
            return (Criteria) this;
        }

        public Criteria andUpdateTimeNotBetween(Date value1, Date value2) {
            addCriterion("update_time not between", value1, value2, "updateTime");
            return (Criteria) this;
        }
    }

    public static class Criteria extends GeneratedCriteria {

        protected Criteria() {
            super();
        }
    }

    public static class Criterion {
        private String condition;

        private Object value;

        private Object secondValue;

        private boolean noValue;

        private boolean singleValue;

        private boolean betweenValue;

        private boolean listValue;

        private String typeHandler;

        public String getCondition() {
            return condition;
        }

        public Object getValue() {
            return value;
        }

        public Object getSecondValue() {
            return secondValue;
        }

        public boolean isNoValue() {
            return noValue;
        }

        public boolean isSingleValue() {
            return singleValue;
        }

        public boolean isBetweenValue() {
            return betweenValue;
        }

        public boolean isListValue() {
            return listValue;
        }

        public String getTypeHandler() {
            return typeHandler;
        }

        protected Criterion(String condition) {
            super();
            this.condition = condition;
            this.typeHandler = null;
            this.noValue = true;
        }

        protected Criterion(String condition, Object value, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.typeHandler = typeHandler;
            if (value instanceof List<?>) {
                this.listValue = true;
            } else {
                this.singleValue = true;
            }
        }

        protected Criterion(String condition, Object value) {
            this(condition, value, null);
        }

        protected Criterion(String condition, Object value, Object secondValue, String typeHandler) {
            super();
            this.condition = condition;
            this.value = value;
            this.secondValue = secondValue;
            this.typeHandler = typeHandler;
            this.betweenValue = true;
        }

        protected Criterion(String condition, Object value, Object secondValue) {
            this(condition, value, secondValue, null);
        }
    }
}